@use "lib/viewport";

// Common
// global styles that apply to the Discourse application specifically
// BEWARE: changing these styles implies they take effect anywhere they are seen
// throughout the Discourse application
:root {
  --d-max-width: 1110px;
  --d-input-bg-color: var(--secondary);
  --d-input-text-color: var(--primary);
  --d-input-border: 1px solid var(--input-border-color);
  --d-input-bg-color--disabled: var(--primary-very-low);
  --d-input-text-color--disabled: var(--primary-medium);
  --d-input-border--disabled: 1px solid var(--primary-low);
  --d-nav-color: var(--primary);
  --d-nav-bg-color: transparent;
  --d-nav-color--hover: var(--tertiary);
  --d-nav-bg-color--hover: transparent;
  --d-nav-color--active: var(--tertiary);
  --d-nav-bg-color--active: transparent;
  --d-nav-border-color--active: var(--d-nav-color--active);
  --d-nav-underline-height: 0.125em;
  --d-nav-font-size: initial;
  --d-input-focused-color: var(--tertiary);
  --d-category-border-box-width: 2px;
  --d-category-box-background-color: var(--secondary);
  --d-category-border-accent-width: 6px;
  --safe-area-inset-bottom: env(safe-area-inset-bottom);
  --nav-space: var(--space-3);
  --nav-horizontal-padding: 0em;
  --d-main-content-gap: var(--space-8);
  --main-outlet-padding-top: var(--space-6);
  --main-outlet-padding-x: 0em;
  --main-outlet-padding-bottom: 0em;
  --table-border-width: 1px;
  --d-topic-list-avatar-size: 24px;
  --d-topic-list-title-font-size: var(--font-up-1);
  --d-topic-list-metadata-top-space: var(--space-1);
  --d-topic-list-data-padding-y: var(--space-3);
  --d-topic-list-data-padding-x: var(--space-1);
  --d-topic-list-header-data-padding-y: var(--space-3);
  --d-topic-list-header-data-padding-x: var(--space-1);
  --d-topic-list-likes-views-posts-width: 4.3em;
  --d-topic-list-data-padding-inline-start: var(--space-3);
  --d-topic-list-data-padding-inline-end: var(--space-3);
  --d-topic-list-data-font-size: var(--font-0);
  --category-boxes-text-alignment: center;
  --d-topic-list-header-background-color: var(--secondary);
  --d-topic-list-header-text-color: var(--primary-medium);
  --d-topic-list-margin-y: 0em;
  --d-topic-list-margin-x: 0em;
  --d-topic-list-margin-bottom: 10px;
  --d-tag-horizontal-padding: 0em;
  --d-tag-font-weight: initial;
  --d-tag-font-size: var(--font-0);
  --d-tag-border-radius: 0px;
  --d-tag-background-color: transparent;
  --category-badge-title-color: currentcolor;
  --category-boxes-description-text-color: var(--primary-med-or-secondary-high);
  --d-category-boxes-gap: var(--space-6);
  --category-boxes-title-font-size: var(--font-up-2);
  --d-category-boxes-margin-top: var(--space-4);
  --d-categories-list-title-margin-bottom: 0em;
  --d-header-padding-x: 0.67em;
  --d-table-border-top-height: 3px;
  --d-wrap-padding-x: 0.67em;
  --topic-title-font-weight: 400;
  --topic-title-font-weight--visited: 400;
  --topic-list-item-background-color: var(--secondary);
  --topic-list-item-background-color--visited: var(--secondary);
  --list-container-padding-x: 0em;
  --d-topic-list-header-font-size: initial;
}

// Animation Keyframes
@keyframes rotate-forever {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(360deg);
  }
}

@keyframes float-down {
  0% {
    opacity: 0;
    transform: translateY(-10px);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes float-up {
  0% {
    opacity: 0;
    transform: translateY(10px);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes background-fade-highlight {
  0% {
    background-color: var(--tertiary-low);
  }

  100% {
    background-color: transparent;
  }
}

// placeholder
@keyframes placeHolderShimmer {
  0% {
    background-position: -1000px 0;
  }

  100% {
    background-position: 1100px 0;
  }
}

@media (prefers-reduced-motion: no-preference) {
  .placeholder-animation {
    animation-duration: 4s;
    animation-fill-mode: forwards;
    animation-iteration-count: infinite;
    animation-name: placeHolderShimmer;
    animation-timing-function: linear;
    background: linear-gradient(
      to right,
      var(--primary-very-low) 10%,
      var(--primary-low) 18%,
      var(--primary-very-low) 33%
    );
  }
}

// Base Elements
html {
  height: 100%;
}

body {
  background-attachment: fixed;
  background-size: cover;
  min-height: 100%;
  box-sizing: border-box;

  &.dragging {
    cursor: ns-resize;
  }

  @include clearfix;

  @include viewport.until(sm) {
    body {
      min-width: 0;
    }
  }
}

// setting a static limit on big and small prevents nesting abuse
big {
  font-size: var(--font-up-5);
}

small {
  font-size: var(--font-down-2);
}

blockquote {
  @include post-aside;
}

code,
pre {
  font-family: var(--d-font-family--monospace);
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--heading-font-family);
  margin-top: 0;
  margin-bottom: 0.5rem;
}

a.cancel {
  margin-left: var(--space-5);
  line-height: normal;
  color: var(--primary-high);
  transition: var(--d-button-transition);

  &:hover {
    color: var(--danger);
  }
}

ul.breadcrumb {
  margin: 0 10px 0 10px;
}

a.no-href {
  cursor: pointer;
}

img.avatar {
  border-radius: 50%;
}

// don't wrap relative dates; we want Jul 26, '15, not: Jul
//                                                      26,
//                                                      '15
span.relative-date {
  white-space: nowrap;
}

legend {
  color: var(--primary-high);
  font-weight: bold;
  font-size: var(--font-down-1-rem);
}

label {
  display: flex;
  margin-bottom: 5px;
  align-items: flex-start;
  color: var(--primary-high);

  &:not(.checkbox-label) {
    font-weight: bold;
  }

  > .d-icon {
    align-self: center;
    margin-right: 4px;
  }

  a {
    // flex removes whitespace characters between text nodes and elements
    // so we need to add it back
    margin: 0 var(--space-1);
  }
}

input {
  @include viewport.from(sm) {
    width: 210px;
    margin-left: 0;
  }

  &[type="radio"],
  &[type="checkbox"] {
    margin-top: 0.17em;
    margin-right: 0.43em;
    margin-left: 0.1em;
    line-height: var(--line-height-small);
    cursor: pointer;
    flex-shrink: 0; // Adding for safety, Safari will shrink checkboxes
  }

  &[type="submit"],
  &[type="reset"],
  &[type="button"],
  &[type="radio"],
  &[type="checkbox"] {
    width: auto;
  }

  &.invalid {
    background-color: var(--danger-low);
  }

  .radio &[type="radio"],
  .checkbox &[type="checkbox"] {
    float: left;
    margin-left: -18px;
  }

  &[type="text"],
  &[type="password"],
  &[type="datetime"],
  &[type="datetime-local"],
  &[type="date"],
  &[type="month"],
  &[type="time"],
  &[type="week"],
  &[type="number"],
  &[type="email"],
  &[type="url"],
  &[type="search"],
  &[type="tel"],
  &[type="color"] {
    @include form-item-sizing;
    appearance: none;
    display: inline-block;
    margin-bottom: 9px;
    color: var(--d-input-text-color);
    background-color: var(--d-input-bg-color);
    border: var(--d-input-border);
    border-radius: var(--d-input-border-radius);
    color-scheme: var(--scheme-type);

    &:focus {
      @include default-focus;
    }
  }

  &[type="color"] {
    border: var(--d-input-border);
    border-radius: var(--d-input-border-radius);
    cursor: pointer;
    padding: 0;
    margin-bottom: 0;

    &::-webkit-color-swatch-wrapper {
      padding: 0;
    }

    &::-webkit-color-swatch {
      border: none;
      border-radius: 0;
    }
  }

  &[type="time"] {
    max-width: 140px;
  }
}

input[type="search"] {
  &::-webkit-search-cancel-button,
  &::-webkit-search-decoration {
    appearance: none;
  }
}

// Fixes Safari height inconsistency
::-webkit-datetime-edit {
  display: inline;
}

// Fixes Webkit inconsistencies (Safari/Chrome)
::-webkit-datetime-edit-fields-wrapper,
::-webkit-datetime-edit-text,
::-webkit-datetime-edit-month-field,
::-webkit-datetime-edit-day-field,
::-webkit-datetime-edit-year-field {
  padding-top: 0;
  padding-bottom: 0;
}

::placeholder {
  text-overflow: ellipsis;
}

textarea {
  padding: $vpad $hpad;
  box-sizing: border-box;
  height: auto;
  background-color: var(--secondary);
  border: 1px solid var(--primary-400);
  border-radius: 0;

  &:focus {
    @include default-focus;
  }

  @include viewport.from(sm) {
    width: 210px;
    margin-left: 0;
  }
}

select {
  border: 1px solid var(--primary-low);
  background: var(--secondary);

  &[multiple],
  &[size] {
    height: auto;
  }

  @include viewport.from(sm) {
    width: 220px;
  }
}

select,
input[type="file"] {
  line-height: var(--line-height-large);
}

table {
  th {
    font-weight: normal;
    color: var(--primary-medium);
    text-align: left;
    padding: var(--space-2);
  }
}

input,
select,
textarea {
  color: var(--d-input-text-color);
  caret-color: currentcolor;

  &[disabled],
  &[readonly] {
    cursor: not-allowed;
    color: var(--d-input-text-color--disabled);
    background-color: var(--d-input-bg-color--disabled);
    border: var(--d-input-border--disabled);
  }

  &:focus:required:invalid {
    color: var(--danger);
    border-color: var(--danger);
    outline: 1px solid var(--danger);
  }
}

@include viewport.from(sm) {
  label,
  input,
  button,
  select,
  textarea {
    font-size: var(--font-0);
    font-weight: normal;
    line-height: var(--line-height-medium);
  }

  select,
  textarea {
    display: inline-block;
    margin-bottom: 9px;
    font-size: var(--font-0);
    line-height: var(--line-height-large);
    color: var(--primary);
  }

  .input {
    &-xxlarge,
    &-xxlarge + .control-instructions {
      width: 530px;
    }
  }
}

// Common Classes
.sortable {
  white-space: nowrap;
  cursor: pointer;
  user-select: none;

  .discourse-no-touch & {
    &:hover,
    &:focus {
      background-color: var(--d-hover);
    }
  }

  .d-icon {
    margin-left: var(--space-1);
  }

  button {
    background: none;
    border: none;
    padding: 0;
  }
}

.radio,
.checkbox {
  min-height: 18px;
  padding-left: 18px;

  .controls > &:first-child {
    padding-top: 5px;
  }

  &.inline {
    display: inline-block;
    padding-top: 5px;
    margin-bottom: 0;
    vertical-align: middle;
  }
}

.radio.inline .radio.inline,
.checkbox.inline .checkbox.inline {
  margin-left: 0.67em;
}

.container {
  @extend .clearfix;
}

.wrap {
  max-width: var(--d-max-width);
  margin-right: auto;
  margin-left: auto;
  padding: 0 var(--d-wrap-padding-x);

  @include viewport.until(sm) {
    min-width: 0;
  }

  .contents {
    position: relative;
  }
}

.boxed {
  height: 100%;

  &.white {
    background-color: var(--secondary);
  }
}

.full-width {
  margin-left: 12px;

  @include viewport.until(sm) {
    min-width: 0;
  }
}

.clear-transitions {
  transition: none !important;
}

.tip {
  display: inline-block;

  &.good {
    color: var(--success);
  }

  &.bad {
    color: var(--danger);
  }
}

.avatar-wrapper {
  background-color: var(--secondary);
  display: inline-block;
  border-radius: 50%;
}

.unread-high-priority-notifications {
  color: var(--secondary);
  background: var(--success);

  &.badge-notification[href] {
    color: var(--secondary);
  }
}

.d-header .header-dropdown-toggle .do-not-disturb-background {
  position: absolute;
  left: 0;
  bottom: -1px;
}

.do-not-disturb-background {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1em;
  background-color: var(--secondary);
  border-radius: 50%;
  height: 1em;
  box-shadow: 0 0 0 2px var(--secondary);

  .d-icon.d-icon-discourse-dnd {
    color: var(--header_primary-medium) !important;
    font-size: 1em;
    height: 1em;
    width: 1em;
  }
}

.d-header .header-dropdown-toggle .user-status-background {
  position: absolute;
  right: -3px;
  bottom: -1px;
}

.user-status-background {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.25em;
  height: 1.25em;
  background-color: var(--secondary);
  border-radius: 50%;

  .emoji {
    width: 14px;
    height: 14px;
    display: block;
  }
}

.fade {
  opacity: 0;
  transition: opacity 0.15s linear;

  &.in {
    opacity: 1;
  }
}

.inline-spinner {
  display: inline-block;
  margin: 0;
}

.spinner {
  margin: 20px auto 20px auto;
  position: relative;
  animation: rotate-forever 1s infinite linear;
  height: 30px;
  width: 30px;
  border: 4px solid var(--primary-low-mid);
  border-right-color: transparent;
  border-radius: 50%;

  &.small {
    width: 10px;
    height: 10px;
    margin: 0;
    display: inline-block;
  }
}

.content-list {
  h3 {
    color: var(--primary-medium);
    font-size: var(--font-up-1);
    padding-left: 5px;
    margin-bottom: 10px;
  }

  ul {
    list-style: none;
    margin: 0;

    li {
      border-bottom: 1px solid var(--content-border-color);

      &:first-of-type {
        border-top: 1px solid var(--content-border-color);
      }

      a {
        display: block;
        padding: 10px;
        color: var(--primary);

        &:hover {
          background-color: var(--primary-low);
          color: var(--primary);
        }

        &.active {
          font-weight: bold;
          color: var(--primary);
          background: var(--d-selected);
        }
      }
    }
  }
}

form {
  margin: 0;
}

.control-group {
  margin-bottom: 9px;
}

.controls-dropdown {
  margin-bottom: 10px;
}

.control-instructions {
  color: var(--primary-medium);
  font-size: 0.875rem;
}

.form-vertical {
  input,
  textarea,
  select {
    display: inline-block;
    margin-bottom: 0;
    flex: 0 0 auto;
    max-width: 100%;
  }

  .control-label:not(.checkbox-label) {
    font-family: var(--heading-font-family);
    font-weight: bold;
    font-size: var(--font-up-2);
    line-height: var(--line-height-large);
  }

  .control-group,
  .controls {
    margin-left: 0;

    label {
      font-weight: normal;
    }
  }

  .control-group {
    margin-bottom: var(--space-5);
  }

  .radio-group {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
  }

  .controls:not(.controls-dropdown) + .controls {
    margin-top: var(--space-2);
  }
}

.form-horizontal {
  input[type="text"],
  input[type="password"],
  textarea {
    margin-bottom: 0;
  }

  .control-group {
    margin-bottom: 18px;

    @include clearfix;
  }

  .control-indent {
    margin-left: 20px;
    margin-bottom: 10px;
  }

  .control-label {
    margin: 6.5px;
    float: left;
    width: 140px;
    text-align: right;
    font-weight: bold;
  }

  .controls {
    margin-left: 160px;
  }
}

// Special elements
#main-outlet-wrapper {
  box-sizing: border-box;
  width: 100%;
  display: grid;
  grid-template-areas:
    "sidebar content"
    "sidebar below-content";
  grid-template-rows: 1fr auto;
  grid-template-columns: 0 minmax(0, 1fr); // 0 column width needs to be set for CSS transitions
  gap: 0;

  #main-outlet {
    grid-area: content;
  }
}

#main-outlet {
  padding: var(--main-outlet-padding-top) var(--main-outlet-padding-x)
    var(--main-outlet-padding-bottom);

  .mobile-view & {
    padding-top: var(--space-5); // notch avoidance

    @media only screen and (orientation: landscape) {
      padding-right: env(safe-area-inset-right);
      padding-left: env(safe-area-inset-left);
    }
  }
}

#main {
  position: relative;

  img.avatar {
    &.header {
      width: 45px;
      height: 45px;
    }

    &.medium {
      width: 32px;
      height: 32px;
    }

    &.small {
      width: 25px;
      height: 25px;
    }

    &.tiny {
      width: 20px;
      height: 20px;
    }
  }

  .user-list {
    .user {
      padding-bottom: 5px;
    }
  }
}

#loading-message {
  position: absolute;
  font-size: var(--font-up-5);
  text-align: center;
  top: 120px;
  left: 500px;
  color: var(--primary);
}

#footer {
  .container {
    height: 50px;

    .contents {
      padding-top: 10px;

      a[href] {
        color: var(--secondary);
      }
    }
  }
}

.inline {
  display: inline;
}

.pref-email {
  display: grid;
  grid-template-areas:
    "title title"
    "email email"
    "instructions controls";
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 0 var(--space-2);

  .control-label {
    grid-area: title;
  }

  .emails {
    grid-area: email;
  }

  .instructions {
    grid-area: instructions;
  }

  .controls {
    margin-top: var(--space-2);
    grid-area: controls;
  }

  .resend-email-confirmation {
    background: transparent;
    border: none;
    color: var(--tertiary);
    padding: 0;
    text-align: left;
  }

  .row {
    border-bottom: 1px solid var(--content-border-color);
    padding: var(--space-1) 0;
    display: grid;
    grid-template-areas:
      "email dropdown"
      "meta dropdown";
    grid-template-columns: 1fr auto;
    grid-template-rows: 1fr auto;
  }

  .email-first {
    grid-area: email;
    align-self: center;
    overflow-wrap: break-word;
    min-width: 0;
  }

  .email-second {
    grid-area: meta;
    color: var(--primary-medium);

    .primary {
      color: var(--success);
    }

    .unconfirmed {
      font-style: italic;
    }
  }

  .email-dropdown {
    grid-area: dropdown;
    align-self: center;
    justify-self: end;

    summary {
      background: transparent;

      .d-icon {
        color: var(--primary-high);
      }
    }
  }

  .dropdown-menu {
    width: 120px;
  }
}

.topic-statuses {
  // avoid adding margin/padding on this parent; sometimes it appears as an empty container
  float: left;

  .topic-status {
    margin: 0;
    display: inline-flex;
    color: var(--primary-medium);
    margin-right: 0.2em;

    .d-icon {
      height: 0.74em;
      width: 0.74em;
    }
  }

  .topic-status-warning .d-icon-envelope {
    color: var(--danger);
  }
}

.broken-theme-alert-banner {
  font-size: var(--base-font-size);
  font-weight: bold;
  padding: 5px 0;
  background: var(--danger);
  text-align: center;
  z-index: z("max");
  color: var(--secondary);

  a {
    color: var(--secondary);
    text-decoration: underline;
  }

  .theme-error-suffix {
    font-weight: normal;
  }
}

.controls {
  .grouped-control {
    display: flex;
    flex-direction: column;

    .grouped-control-label {
      padding: var(--space-1) 0;
    }

    .grouped-control-field {
      flex: 1 0 auto;
      display: flex;
      padding-bottom: var(--space-1);

      label {
        margin: 0;
      }
    }
  }
}

a#user-nav-skip-link,
a#skip-link {
  padding: var(--space-1) var(--space-2);
  position: fixed;
  top: -50px;
  left: var(--space-4);
  color: var(--secondary);
  background: var(--tertiary);
  transition: top 0.3s ease-out;
  z-index: z("header") + 1;

  &:focus {
    top: 0;
    transition: top 0.15s ease-in;
  }
}

.scroll-lock {
  overflow: hidden !important;
  margin-right: var(--scroll-gap, 0);
}

body.has-sidebar-page {
  .wrap {
    // increase page max-width to accommodate sidebar width
    max-width: calc(var(--d-sidebar-width) + var(--d-max-width));
  }

  #main-outlet-wrapper {
    grid-template-columns: var(--d-sidebar-width) minmax(0, 1fr);
    gap: 0 var(--d-main-content-gap);
    padding-left: 0;

    @include viewport.until(lg) {
      --d-main-content-gap: var(--space-4);
    }
  }
}

@media (prefers-reduced-motion: no-preference) {
  body.sidebar-animate {
    #main-outlet-wrapper {
      transition-property: grid-template-columns, max-width;
      transition-timing-function: var(--d-sidebar-animation-ease);
      transition-duration: var(--d-sidebar-animation-time);
    }

    .d-header-wrap .wrap {
      transition: max-width var(--d-sidebar-animation-time)
        var(--d-sidebar-animation-ease);
    }
  }
}

.mobile-view {
  .boxed {
    .contents {
      // adds space below avatar
      padding: 10px 0 0 0;
    }
  }
}

.ios-device {
  textarea {
    background-color: var(--secondary);
    -webkit-tap-highlight-color: transparent;
  }

  input#reply-title {
    -webkit-tap-highlight-color: transparent;
  }
}

// todo: replace — legacy, currently only seems to be used for assigns
.mobile-nav {
  margin: 0;
  padding: 0;
  list-style: none;
  position: relative;

  a {
    color: var(--primary);

    .d-icon {
      margin-right: var(--space-1);
      color: var(--primary-medium);
    }
  }

  > li > a.expander {
    display: flex;
    align-items: center;
    border-color: var(--primary-medium);
    max-width: 100%;

    @include form-item-sizing;

    .selection {
      max-width: 120px;

      @include ellipsis;
    }

    > .d-icon {
      &:last-of-type {
        margin-left: auto;
        margin-right: 0;
      }
    }
  }

  .drop {
    display: none;

    &.expanded {
      left: 0;
      display: block;
      position: absolute;
      z-index: z("dropdown");
      background-color: var(--secondary);
      width: 100%;
      list-style: none;
      margin: 0;
      padding: 5px;
      border: 1px solid var(--content-border-color);
      box-sizing: border-box;

      li {
        margin: 5px 0;
        padding: 0;

        a {
          height: 100%;
          display: block;
          padding: 5px 8px;

          @include ellipsis;
        }
      }
    }
  }
}
